<?php

class User {
	private $_db;
	private $_data;
	private $_sessionName;
	private $_cookieName;
	private $_isLoggedIn;
	
	public function __construct($user = null){

		$this->_db = DB::getInstance();
		$this->_sessionName = Config::get('session/session_name');
		$this->_cookieName = Config::get('remember/cookie_name');



		if (!$user) { 
			if (Session::exists($this->_sessionName)) {
				$user = Session::get($this->_sessionName);
				
				if ($this->find($user)) {
						$this->_isLoggedIn = true;
						

					}else {}	

			}
		} else {
			$this->find($user);
		}

	}

	public function create($fields = array()){

		if (!$this->_db->insert('users', $fields)) {
			throw new Exception("There was an error creating an account.");
			
		}

	}

	public function update($fields = array(), $id = null){

		if (!$id && $this->_isLoggedIn) {
			$id = $this->data()->id;
		}

		if (!$this->_db->update('users', $id, $fields)) {
			throw new Exception("there was an error updating.");
			
		}
	}

	public function find($user = null){

		if ($user) {
			$field = (is_numeric($user)) ? 'id' : 'username';
			$data = $this->_db->get('users', array($field, '=', $user));

			if ($data->count()) {
				$this->_data = $data->first();
				return true;
			}
		}
		return false;
	}

	public function login($username = null,  $password = null, $rememeber = false){


		if (!$username && !$password && $this->exists()) {
			Session::put($this->_sessionName, $this->data()->id);
		}else {
			$user = $this->find($username);
			if ($user) {

				if ($this->data()->password === Hash::make($password, $this->data()->salt)) {
					//echo "okay hashed password <br/>"; 
					Session::put($this->_sessionName, $this->data()->id);
					
					if ($rememeber) {
						$hash = Hash::unique();
						$hashCheck = $this->_db->get('user_session', array('user_id', '=', $this->data()->id));
	
						if (!$hashCheck->count()) {
							$this->_db->insert('user_session', array(
								'user_id' => $this->data()->id, 
								'hash' => $hash
							));
						}else {
							$hash =  $hashCheck->first()->hash;
						}
						Cookie::put($this->_cookieName, $hash, Config::get('remember/cookie_expiry'));
					}
				
					return true;
				}

			}
		}

		return false;
	}

	public function exists(){
		return (!empty($this->_data)) ? true : false;
	}

	public function data(){
		return $this->_data;
	}

	public function isLoggedIn(){
		return $this->_isLoggedIn;

	}

	public function logout(){

		$this->_db->delete('user_session', array('user_id', '=', $this->data()->id));

		Session::delete($this->_sessionName);
		Cookie::delete($this->_cookieName);
	}

	public function hasPermission($key){
		$group = $this->_db->get('groups', array('id', '=', $this->data()->group));
		//print_r($group->first());
		if ($group->count()) {
			$permissions = json_decode($group->first()->permissions, true);
			//print_r($permissions);
			if ($permissions[$key] == true) {
				return true;
			}
		}
		return false;
	}
}